package br.academia.arq.dao;

import java.util.Collection;
import java.util.HashMap;

import org.hibernate.HibernateException;
import org.hibernate.Query;

import br.academia.arq.erros.DAOException;
import br.academia.dominio.Estado;
import br.academia.util.Validador;


/**
 * Dao com operações referentes a Estado
 * @see Estado
 */
public class EstadoDAO extends GenericDAO{
	
	/**
	 * Método que retorna uma entidade do classe Estado que possua o
	 * nome idêntico ao nome passado como parâmetro
	 * @param nome
	 * @return
	 * @throws HibernateException
	 * @throws DAOException
	 */
	public Estado findEstadoByNome(String nome) throws HibernateException, DAOException{
		String hql = "select e from Estado e where e.nome = :nome ";
		
		Query q = getSession().createQuery(hql);
		
		q.setParameter("nome", nome);
		
		Estado estado = (Estado) q.uniqueResult();
		
		return estado;
	}
	
	/**
	 * Método que retorna uma entidade do classe Estado que possua
	 * sigla idêntica à sigla passada como parâmetro
	 * @param nome
	 * @return
	 * @throws HibernateException
	 * @throws DAOException
	 */
	public Estado findEstadoBySigla(String sigla) throws HibernateException, DAOException{
		String hql = "select e from Estado e where e.sigla = :sigla";
		
		Query q = getSession().createQuery(hql);
		
		q.setParameter("sigla", sigla);
		
		Estado estado = (Estado) q.uniqueResult();
		
		return estado;
	}
	
	/**
	 * Método que retorna cargos que tenham nome ou descrição parecidos
	 * com os itens do ideal passado como parâmetro
	 * @param ideal
	 * @return
	 * @throws HibernateException
	 * @throws DAOException
	 */
	public Collection<Estado> findEstadoLike(Estado estado) throws HibernateException, DAOException{
		String hql = "select e from Estado i where 1 = 1 ";
		HashMap<String, Object> parametros = new HashMap<String, Object>();
			
		if(!Validador.isEmpty(estado.getNome())){
			hql += " and e.nome like :nome ";
			parametros.put("nome", "%" + estado.getNome() + "%");
		}
		
		if(!Validador.isEmpty(estado.getSigla())){
			hql += " and e.estado like :estado ";
			parametros.put("descricao", "%" + estado.getSigla() + "%");
		}
		
		Query q = getSession().createQuery(hql);
		
		setParametros(parametros, q);
		
		@SuppressWarnings("unchecked")
		Collection<Estado> estados = q.list();
		
		return estados;
	}
}
